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//Question : Ecrire une fonction qui fait la 
concaténation de deux chaines de caractères saisies par 
l'utilisateur : 

#include <stdio.h> 

#include <stdlib.h> 

#include <string.h> 

#define N 50 

char * concatene (char* chl ,char* ch2) 

{char *res ,* p; 

int nl=strlen(chl), n2 =strlen(ch2) , i=0; 

res=(char*) malloc ((strlen(chl)+strlen(ch2)+1) *sizeof (ch 

ar) ) ; 

p=res; int k=0 ; 

for (i=0;i<nl;i++) 

{ 

/* *p=chl[i] ; 

P++; */ 

res [k++]=chl[i]; 

} 

for (i=0;i<n2;i++) 

{ 

/*p=ch2[i]; 

P++; */ 

res [k++]=ch2[i]; 


} 

res [k]= ’\0' ; 
return res; 


} 


int main () 

{ 

char text[N] ; 
int nl,n2; 

char*chl , *ch2 , *f inal ; 
printf ( "Chaine l:\t"); 
gets (text); 
nl=strlen(tex t) ; 

chl=(char*) malloc (nl*sizeof (char)); 
strcpy (chl , text); 

printf ( "Chaine 2:\t"); 
gets (text); 
n2=strlen(tex t) ; 

ch2=(char*) malloc (n2*sizeof (char)); 
strcpy (ch2,text); 
f inal=concatene (chl, ch2 ) ; 
printf ( "%s\n" ,final); 

return 0 ; 

} 


SCREEN de l'execution : 
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//Question : 

#include <stdio.h> 

#include <stdlib.h> 

#include <string.h> 

#define N 50 

//Question : 

void remplir (char**T, int n) 

{ 

int i ; 

for (i=0 ;i<n ;i++) 

{ 

printf ("Nom:\t") ; 
gets ( T [i] ) ; 

} } 

//Question : 

void afficher (char**T, int n) 

{ 

int i ; 

for (i=0 ;i<n ; i++) 

{ 

printf ("Nom %d : %s\t",i+l ,T[i]); 

} 

} 

//Question : 

int recherche (char*T[], int n,char*nom) 

{ 

int i ; 

for (i=0 ;i<n;i++) 

if (strcmp(T[i], nom)==0) return i; 
return -1; 

} 

//Question : 

void bulle (char*T[], int n) 

{ 


int i , j ; 


char Aux[N]=""; 

for (j=0;j<n;j++) 

for (i=n-l;i>j;i--) 

{ 

if (strcmp(T[i] ,T [ i — 1 ])<0) 

{ strcpy (Aux, T [ i — 1 ]); 
strcpy (T[ i — 1 ] ,T [i]); 
strcpy(T[i],Aux); 

} 

} 

afficher (T, n); 

} 

//Question : Programme principal 

int main () 

{ 

int n; int c; 
int i; 

char **Tnom; 
char*x; 


printf ( "Combien de Noms dans le tableau :\t"); 

scanf ( "%d" , &n); 
getchar (); 

/★^Allocation dynamique tableau 2 dimensions***/ 

Tnom=(char**) malloc ( (n*sizeof (char))); 
for (i=0;i<n;i++) 

Tnom [i]=(char*) malloc (N*sizeof (char)); 

/★★★★★/ 

remplir (Tnom,n); 
afficher (Tnom,n); 

x=(char*) malloc (N*sizeof (char)); 


printf ("\n Tri par ordre alphabetique\n") ; 
bulle (Tnom,n); 


printf("\n Rechercher : \t") ; scanf ("%s",x) ; 
c=recherche(Tnom,n,x); 

if (c==-l) printf("\n pas trouve\n") ; 

else printf("\n se trouve a la ligne %d\n",c+l); 


return 0 ; 

} 


CS "C:\Users\user\Desktop\TP3\Ex3 TP3.exe - ' 

Combien de Noms dans le tableau : 4 

****Remplissage**** 

Nom: Simohamed Execution du 

Nom: Yasser programme principal 

Nom: Faouzi 

Nom: Younes ^ 

****Affichage**** 

Nom 1 : Simohamed Nom 2 : Yasser Nom 3 : Faouzi Nom 4 : Younes 

Appuyez sur ENTRER pour trier 

**Tri par ordre alphabétique** 

Nom 1 : Faouzi Nom 2 : Simohamed Nom 3 : Yasser Nom 4 : Younes 

Appuyez sur ENTRER pour rechercher 

Rechercher : Simohamed 


se trouve a la ligne 2 

Process returned 0 (0x0) execution time : 27.737 s 
Press any key to continue. 



